set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
GO
/* *******************************************************************
** DATE :
** Writer :
** Memo :
******************************************************************** */
CREATE PROCEDURE [dbo].[TSP_UserCard_GetInfo]
(
	@IsTransaction	tinyint			= 0
,	@ErrorCode		int				= 0		OUTPUT
,	@ErrorMessage	nvarchar( 1000 )= ''	OUTPUT

,	@strCardNo	varchar(100)	= NULL	OUTPUT --IN
,	@n4UserCardNo	int	= NULL	OUTPUT --IN
,	@n4UserNo	int	= NULL	OUTPUT
,	@CodeStatus	tinyint	= NULL	OUTPUT
,	@dtCreateDate	datetime	= NULL	OUTPUT
,	@dtModifyDate	datetime	= NULL	OUTPUT
,	@dtRemoveDate	datetime	= NULL	OUTPUT
,	@strModifyManagerName	nvarchar(100)	= NULL	OUTPUT
,	@strDesc	nvarchar(1000)	= NULL	OUTPUT
)
as
Set NOCOUNT ON

-- Frk Default Value
DECLARE @FrkDateNow DateTime
DECLARE @FrkRowCount int
DECLARE @FrkTranCount int
DECLARE @FrkErrorCode int
DECLARE @FrkErrorMessage nvarchar( 1000 )
Set @FrkDateNow = GetDate()
set @FrkTranCount = @@TRANCOUNT
-- Frk Check


If ( @IsTransaction = 0 )
Begin
	If ( @FrkTranCount < 1 )
	Begin
		Set @FrkErrorCode = -1
		Set @FrkErrorMessage = 'Transaction.'
		goto ERROR
	End
	Else If ( @FrkTranCount > 1 )
	Begin
		Set @FrkErrorCode = -2
		Set @FrkErrorMessage = 'Transaction.'
		goto ERROR
	End
End
Else
Begin
	If ( @FrkTranCount <> 0 )
	Begin
		Set @FrkErrorCode = -3
		Set @FrkErrorMessage = 'Transaction.'
		goto ERROR
	End
	Begin Tran
End

-- Implementation
IF ( @n4UserCardNo IS NOT NULL )
BEGIN
	SELECT
		@n4UserCardNo = n4UserCardNo
	,	@n4UserNo = n4UserNo
	,	@strCardNo = strCardNo
	,	@CodeStatus = CodeStatus
	,	@dtCreateDate = dtCreateDate
	,	@dtModifyDate = dtModifyDate
	,	@dtRemoveDate = dtRemoveDate
	,	@strModifyManagerName = strModifyManagerName
	,	@strDesc = strDesc
	FROM
		dbo.TB_UserCard WITH (NOLOCK)
	WHERE
		n4UserCardNo = @n4UserCardNo
END
ELSE
BEGIN
	SELECT
		@n4UserCardNo = n4UserCardNo
	,	@n4UserNo = n4UserNo
	,	@strCardNo = strCardNo
	,	@CodeStatus = CodeStatus
	,	@dtCreateDate = dtCreateDate
	,	@dtModifyDate = dtModifyDate
	,	@dtRemoveDate = dtRemoveDate
	,	@strModifyManagerName = strModifyManagerName
	,	@strDesc = strDesc
	FROM
		dbo.TB_UserCard WITH (NOLOCK)
	WHERE
		strCardNo = @strCardNo
END

-- Frk Error Check
SELECT
	@FrkErrorCode = @@ERROR
,	@FrkRowCount = @@RowCount

-- End

COMPLETE:
	If ( @IsTransaction <> 0 )
	Begin
		If ( @@TRANCOUNT = 1 )
		Begin
			Commit Tran
		End
	End
	SET @ErrorCode = 0
	SET @ErrorMessage = ''
	return 0
ERROR:
	If ( @IsTransaction <> 0 )
	Begin
		If ( @@TRANCOUNT = 1 )
		Begin
			Rollback Tran
		End
	End
	SET @ErrorCode = @FrkErrorCode
	SET @ErrorMessage = @FrkErrorMessage
	return @FrkErrorCode
